package com.yss.common.core.web.domain;

import java.io.Serializable;
import java.util.Date;
import java.util.HashMap;
import java.util.Map;

import com.alibaba.excel.annotation.ExcelIgnore;
import com.alibaba.excel.annotation.ExcelProperty;
import com.alibaba.excel.annotation.write.style.ColumnWidth;
import com.baomidou.mybatisplus.annotation.TableField;
import com.baomidou.mybatisplus.extension.activerecord.Model;
import com.fasterxml.jackson.annotation.JsonFormat;
import com.fasterxml.jackson.annotation.JsonIgnore;
import com.fasterxml.jackson.annotation.JsonInclude;
import lombok.Data;
import lombok.EqualsAndHashCode;

/**
 * Entity基类
 */
@Data
@EqualsAndHashCode(callSuper = false)
public class BaseEntity extends Model implements Serializable {
    private static final long serialVersionUID = 1L;

    /**
     * 搜索值
     */
    @ExcelIgnore
    @JsonIgnore
    @TableField(exist = false)
    private String searchValue;

    /**
     * 创建者
     */
    @ColumnWidth(30)
    @ExcelProperty("创建者")
    @TableField("CREATE_BY")
    private String createBy;

    /**
     * 创建时间
     */
    @ColumnWidth(30)
    @ExcelProperty("创建时间")
    @JsonFormat(pattern = "yyyy-MM-dd HH:mm:ss")
    @TableField("CREATE_TIME")
    private Date createTime;

    /**
     * 更新者
     */
    @ColumnWidth(30)
    @ExcelProperty("更新者")
    @TableField("UPDATE_BY")
    private String updateBy;

    /**
     * 更新时间
     */
    @ColumnWidth(30)
    @ExcelProperty("更新时间")
    @JsonFormat(pattern = "yyyy-MM-dd HH:mm:ss")
    @TableField("UPDATE_TIME")
    private Date updateTime;

    /**
     * 备注
     */
    @ColumnWidth(50)
    @ExcelProperty("备注")
    @TableField("REMARK")
    private String remark;

    /**
     * 请求参数
     */
    @ExcelIgnore
    @JsonInclude(JsonInclude.Include.NON_EMPTY)
    @TableField(exist = false)
    private Map<String, Object> params;

    public Map<String, Object> getParams() {
        if (params == null) {
            params = new HashMap<>();
        }
        return params;
    }
}
